app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))
↳ QTRS
↳ DependencyPairsProof
app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))
LAST -> APP2(app2(compose, hd), reverse)
LAST -> APP2(compose, hd)
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(app2(cons, x), l)
INIT -> APP2(app2(compose, tl), reverse)
INIT -> APP2(compose, tl)
APP2(app2(app2(compose, f), g), x) -> APP2(f, x)
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(reverse2, xs)
INIT -> APP2(compose, reverse)
APP2(reverse, l) -> APP2(reverse2, l)
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(app2(reverse2, xs), app2(app2(cons, x), l))
APP2(app2(app2(compose, f), g), x) -> APP2(g, app2(f, x))
APP2(reverse, l) -> APP2(app2(reverse2, l), nil)
INIT -> APP2(app2(compose, reverse), app2(app2(compose, tl), reverse))
app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
LAST -> APP2(app2(compose, hd), reverse)
LAST -> APP2(compose, hd)
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(app2(cons, x), l)
INIT -> APP2(app2(compose, tl), reverse)
INIT -> APP2(compose, tl)
APP2(app2(app2(compose, f), g), x) -> APP2(f, x)
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(reverse2, xs)
INIT -> APP2(compose, reverse)
APP2(reverse, l) -> APP2(reverse2, l)
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(app2(reverse2, xs), app2(app2(cons, x), l))
APP2(app2(app2(compose, f), g), x) -> APP2(g, app2(f, x))
APP2(reverse, l) -> APP2(app2(reverse2, l), nil)
INIT -> APP2(app2(compose, reverse), app2(app2(compose, tl), reverse))
app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(app2(reverse2, xs), app2(app2(cons, x), l))
POL(APP2(x1, x2)) = 1 + x1
POL(app2(x1, x2)) = x1 + x2
POL(cons) = 1
POL(reverse2) = 1
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
APP2(app2(app2(compose, f), g), x) -> APP2(g, app2(f, x))
APP2(app2(app2(compose, f), g), x) -> APP2(f, x)
app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP2(app2(app2(compose, f), g), x) -> APP2(g, app2(f, x))
APP2(app2(app2(compose, f), g), x) -> APP2(f, x)
POL(APP2(x1, x2)) = x1
POL(app2(x1, x2)) = x1 + x2
POL(compose) = 1
POL(cons) = 1
POL(hd) = 0
POL(nil) = 0
POL(reverse) = 0
POL(reverse2) = 0
POL(tl) = 0
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))